<?php
/**
 * 数据库配置文件
 */

// 数据库连接配置
define('DB_HOST', 'localhost');      // 数据库主机
define('DB_NAME', 'ma_appointment'); // 数据库名
define('DB_USER', 'root');           // 数据库用户名
define('DB_PASS', '#Lijunhui123');               // 数据库密码
define('DB_CHARSET', 'utf8mb4');     // 字符集

/**
 * 数据库连接类
 */
class Database {
    private static $instance = null;
    private $conn;
    
    private function __construct() {
        try {
            $this->conn = new PDO(
                "mysql:host=" . DB_HOST . ";dbname=" . DB_NAME . ";charset=" . DB_CHARSET,
                DB_USER,
                DB_PASS,
                array(
                    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
                    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
                    PDO::ATTR_EMULATE_PREPARES => false
                )
            );
        } catch (PDOException $e) {
            die("数据库连接失败: " . $e->getMessage());
        }
    }
    
    // 防止克隆对象
    private function __clone() {}
    
    // 获取数据库连接实例（单例模式）
    public static function getInstance() {
        if (self::$instance === null) {
            self::$instance = new self();
        }
        return self::$instance;
    }
    
    // 获取数据库连接
    public function getConnection() {
        return $this->conn;
    }
    
    // 执行SQL查询
    public function query($sql, $params = []) {
        $stmt = $this->conn->prepare($sql);
        $stmt->execute($params);
        return $stmt;
    }
    
    // 获取单条记录
    public function fetch($sql, $params = []) {
        $stmt = $this->query($sql, $params);
        return $stmt->fetch();
    }
    
    // 获取多条记录
    public function fetchAll($sql, $params = []) {
        $stmt = $this->query($sql, $params);
        return $stmt->fetchAll();
    }
    
    // 获取最后插入的ID
    public function lastInsertId() {
        return $this->conn->lastInsertId();
    }
}
